---
title: Referência da API de importações de configuração
sidebar:
  label: 'astro:config'
i18nReady: true
tableOfContents:
  minHeadingLevel: 2
  maxHeadingLevel: 6
---

import Since from '~/components/Since.astro';

<p><Since v="5.7.0" /></p>

Este módulo virtual `astro:config` expõe uma versão não exaustiva, serializável e tipada da configuração do Astro. Existem dois submódulos para acessar diferentes subconjuntos dos seus valores de configuração: [`/client`](#importando-de-astroconfigclient) e [`/server`](#importando-de-astroconfigserver).

Todos os valores de configuração disponíveis podem ser acessados a partir de `astro:config/server`. No entanto, para código executado no cliente, apenas os valores expostos por `astro:config/client` estarão disponíveis. Isso protege suas informações, disponibilizando apenas alguns dados para o cliente.

## Importando de `astro:config/client`

```js
import {
  i18n, 
  trailingSlash,
  base,
  build,
  site,
} from "astro:config/client";
```
Utilize este submódulo para código do lado do cliente:

```js title="src/utils.js" ins={1} ins="trailingSlash"
import { trailingSlash } from "astro:config/client";

function addForwardSlash(path) {
  if (trailingSlash === "always") {
    return path.endsWith("/") ? path : path + "/"
  } else {
    return path
  }
}
```

Veja mais sobre as configurações de importação disponíveis em `astro:config/client`:

- [`i18n`](/pt-br/reference/configuration-reference/#i18n)
- [`trailingSlash`](/pt-br/reference/configuration-reference/#trailingslash)
- [`base`](/pt-br/reference/configuration-reference/#base)
- [`build.format`](/pt-br/reference/configuration-reference/#buildformat)
- [`site`](/pt-br/reference/configuration-reference/#site)



## Importando de `astro:config/server`

```js
import {
  i18n, 
  trailingSlash,
  base,
  build,
  site,
  srcDir,
  cacheDir,
  outDir,
  publicDir,
  root,
} from "astro:config/server";
```

Essas importações incluem tudo que está disponível em `astro:config/client`, além de informações adicionais e sensíveis sobre a configuração do sistema de arquivos, que não são seguras para expor ao cliente.

Utilize este submódulo para código do lado do servidor:

```js title="astro.config.mjs"
import { integration } from "./integration.mjs";

export default defineConfig({
    integrations: [
      integration(),
    ]
});
```

```js title="integration.mjs" ins={1} ins="outDir"
import { outDir } from "astro:config/server";
import { writeFileSync } from "node:fs";
import { fileURLToPath } from "node:url";

export default function() {
  return {
    name: "internal-integration",
    hooks: {
      "astro:build:done": () => {
        let file = new URL("result.json", outDir);
        // gerar dados a partir de alguma operação
        let data = JSON.stringify([]);
        writeFileSync(fileURLToPath(path), data, "utf-8");
      }
    }
  }
}
```

Veja mais sobre as configurações de importação disponíveis em `astro:config/server`:

- [`i18n`](/pt-br/reference/configuration-reference/#i18n)
- [`trailingSlash`](/pt-br/reference/configuration-reference/#trailingslash)
- [`base`](/pt-br/reference/configuration-reference/#base)
- [`build.format`](/pt-br/reference/configuration-reference/#buildformat)
- [`build.client`](/pt-br/reference/configuration-reference/#buildclient)
- [`build.server`](/pt-br/reference/configuration-reference/#buildserver)
- [`build.serverEntry`](/pt-br/reference/configuration-reference/#buildserverentry)
- [`build.assetsPrefix`](/pt-br/reference/configuration-reference/#buildassetsprefix)
- [`site`](/pt-br/reference/configuration-reference/#site)
- [`srcDir`](/pt-br/reference/configuration-reference/#srcdir)
- [`cacheDir`](/pt-br/reference/configuration-reference/#cachedir)
- [`outDir`](/pt-br/reference/configuration-reference/#outdir)
- [`publicDir`](/pt-br/reference/configuration-reference/#publicdir)
- [`root`](/pt-br/reference/configuration-reference/#root)
